/* 
===========================================================
  PROGRAM PARTNERSHIP — RESPONSIVE STYLESHEET v3.0
  Warung Sambal Bakar Sampurasun
===========================================================
  ✅ Navbar mobile: semua item RATA TENGAH
  ✅ Hero section: FULL VIEWPORT HEIGHT
  ✅ Tombol WA: diperkecil & posisi naik
  ✅ Footer: semua kolom RATA TENGAH
  ✅ Hamburger tetap muncul & berfungsi
  ✅ Semua elemen proporsional & rapat
===========================================================
  BREAKPOINTS:
    Tablet Landscape : 769px – 1024px
    Tablet + Mobile  : ≤ 768px   ← hamburger aktif
    Mobile Large     : ≤ 576px
    Mobile Small     : ≤ 400px
===========================================================
*/


/* ============================================================
   GLOBAL — di luar media query, selalu aktif
============================================================ */
html,
body {
    overflow-x: hidden;
    max-width: 100%;
}


/* ============================================================
   TABLET LANDSCAPE  (769px – 1024px)
   Navbar masih horizontal, layout sedikit lebih kompak
============================================================ */
@media (max-width: 1024px) and (min-width: 769px) {

    .container {
        padding: 0 20px;
    }

    /* Navbar */
    .navbar       { height: 68px; }
    .navbar-nav   { gap: 2px; }
    .nav-link {
        font-size: 0.82rem !important;
        padding: 9px 11px !important;
        height: 38px !important;
    }

    /* Hero */
    .program-hero-section {
        min-height: 100vh;
        margin-top: 68px;
    }
    .program-hero-title    { font-size: 2.6rem; }
    .program-hero-subtitle { font-size: 1rem; }

    /* Stats */
    .creator-stat-number { font-size: 2.2rem; }
    .creator-stat-item   { padding: 20px 10px; }

    /* Countdown */
    .countdown-item   { padding: 14px 18px; min-width: 85px; }
    .countdown-number { font-size: 2.2rem; }

    /* Titles */
    .benefits-title     { font-size: 1.8rem; }
    .works-title        { font-size: 1.8rem; }
    .registration-title { font-size: 1.8rem; }
    .platform-title     { font-size: 1.45rem; }

    /* Cards */
    .creator-benefit-card { padding: 26px 14px; }
    .platform-icon div    { padding: 12px 28px; font-size: 0.95rem; }

    /* WA Button */
    .btn-success {
        max-width: 320px;
        margin: 0 auto;
        padding: 14px 20px;
        font-size: 1rem;
    }
}


/* ============================================================
   TABLET PORTRAIT + MOBILE  (≤ 768px)
   Hamburger aktif, semua section dioptimalkan
============================================================ */
@media (max-width: 768px) {

    .container {
        padding: 0 16px;
    }


    /* =====================================================
       1. NAVBAR — HAMBURGER + MENU RATA TENGAH
    ===================================================== */

    .navbar {
        height: 62px !important;
        padding: 0 16px !important;
    }

    .navbar .container {
        padding: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: nowrap !important;
        height: 62px !important;
    }

    .navbar-brand img {
        height: 40px !important;
    }

    /* --- Hamburger Button: FORCE VISIBLE --- */
    .navbar-toggler {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0;
        width: 44px !important;
        height: 44px !important;
        padding: 0 !important;
        border-radius: 8px !important;
        border: 2px solid rgba(255, 255, 255, 0.5) !important;
        background: rgba(255, 255, 255, 0.1) !important;
        cursor: pointer !important;
        transition: all 0.25s ease !important;
        z-index: 10002 !important;
        position: relative !important;
    }

    .navbar-toggler:hover {
        background: rgba(255, 140, 0, 0.3) !important;
        border-color: #FF8C00 !important;
    }

    .navbar-toggler:focus {
        outline: none !important;
        box-shadow: 0 0 0 3px rgba(255, 140, 0, 0.4) !important;
    }

    /* Icon hamburger — SVG garis putih */
    .navbar-toggler-icon {
        display: block !important;
        width: 22px !important;
        height: 22px !important;
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255%2C255%2C255%2C1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
        background-repeat: no-repeat !important;
        background-position: center !important;
        background-size: 100% !important;
        filter: none !important;
    }

    /* --- Navbar Collapse Drawer --- */
    .navbar-collapse {
        position: fixed !important;
        top: 62px !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        transform: none !important;
        background: linear-gradient(160deg, #5D2906 0%, #3A1A04 100%) !important;
        border-bottom: 3px solid #D2691E !important;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.7) !important;
        z-index: 9998 !important;
        padding: 16px 0 20px !important;
        max-height: calc(100vh - 62px);
        overflow-y: auto;
    }

    /* Nav list — VERTICAL + RATA TENGAH */
    .navbar-nav {
        flex-direction: column !important;
        align-items: center !important;       /* ← RATA TENGAH */
        gap: 4px !important;
        padding: 0 14px !important;
        width: 100% !important;
        position: static !important;
        transform: none !important;
    }

    .nav-item {
        width: 100%;
        text-align: center;                   /* ← teks center */
    }

    /* Nav link — center */
    .nav-link {
        font-size: 0.95rem !important;
        font-weight: 700 !important;
        padding: 13px 20px !important;
        height: auto !important;
        border-radius: 10px !important;
        justify-content: center !important;   /* ← isi link center */
        text-align: center !important;
        border-left: none !important;
        border-bottom: 2px solid transparent !important;
        color: #FFFFFF !important;
        display: flex !important;
        align-items: center !important;
        transition: all 0.2s ease !important;
        transform: none !important;
        box-shadow: none !important;
        width: 100%;
    }

    .nav-link:hover {
        background: rgba(255, 140, 0, 0.18) !important;
        border-bottom-color: #FF8C00 !important;
        transform: none !important;
        box-shadow: none !important;
        padding-left: 20px !important;
    }

    .nav-link.active {
        background: rgba(255, 140, 0, 0.22) !important;
        border-bottom-color: #FF8C00 !important;
    }

    /* Dropdown toggle — arrow tetap inline */
    .dropdown-toggle {
        justify-content: center !important;
    }

    .dropdown-toggle::after {
        margin-left: 8px !important;          /* arrow setelah teks */
    }

    /* Dropdown menu — center */
    .dropdown-menu {
        position: static !important;
        float: none !important;
        background: rgba(0, 0, 0, 0.25) !important;
        border: none !important;
        border-top: 2px solid rgba(255, 140, 0, 0.4) !important;
        border-radius: 10px !important;
        margin: 4px 0 4px 0 !important;
        padding: 8px 0 !important;
        box-shadow: none !important;
        min-width: unset !important;
        animation: none !important;
        backdrop-filter: none !important;
        width: 100%;
    }

    .dropdown-item {
        margin: 2px 8px !important;
        padding: 10px 16px !important;
        font-size: 0.88rem !important;
        border-radius: 8px !important;
        color: #FFFFFF !important;
        transform: none !important;
        text-align: center !important;        /* ← item center */
        justify-content: center !important;
    }

    .dropdown-item:hover {
        padding-left: 16px !important;
        transform: none !important;
        background: rgba(255, 140, 0, 0.15) !important;
    }

    /* Ikon dropdown item tetap kecil */
    .dropdown-item i {
        font-size: 1rem !important;
        width: 24px !important;
        height: 24px !important;
        margin-right: 8px !important;
        background: transparent !important;
    }


    /* =====================================================
       2. HERO SECTION — FULL VIEWPORT
    ===================================================== */

    .program-hero-section {
        min-height: 100svh !important;        /* full tinggi layar */
        height: 100svh !important;
        margin-top: 0 !important;             /* tidak perlu offset, overlay di atas navbar */
        display: flex !important;
        align-items: center !important;
        padding-top: 62px !important;         /* offset navbar */
    }

    .program-hero-content {
        padding: 20px 20px 30px !important;
        width: 100%;
    }

    .program-hero-title {
        font-size: 1.85rem !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        margin-bottom: 14px !important;
        letter-spacing: -0.3px !important;
    }

    .program-hero-subtitle {
        font-size: 0.9rem !important;
        line-height: 1.7 !important;
        margin: 0 auto !important;
        max-width: 480px !important;
        color: rgba(255, 255, 255, 0.9) !important;
    }


    /* =====================================================
       3. STATISTICS COUNTER
    ===================================================== */

    .creator-stats-counter {
        padding: 22px 12px !important;
        margin: 24px auto !important;
        border-radius: 14px !important;
    }

    .creator-stats-counter .row {
        --bs-gutter-x: 10px !important;
        --bs-gutter-y: 10px !important;
    }

    .creator-stat-item {
        padding: 16px 10px !important;
        border-radius: 12px !important;
    }

    .creator-stat-number {
        font-size: 1.8rem !important;
        margin-bottom: 4px !important;
    }

    .creator-stat-label {
        font-size: 0.71rem !important;
        letter-spacing: 0.4px !important;
    }

    .rating-stars-small {
        font-size: 0.76rem !important;
        margin: 3px 0 5px !important;
        gap: 2px !important;
    }


    /* =====================================================
       4. COUNTDOWN TIMER
    ===================================================== */

    .promo-warning-box {
        padding: 18px 14px !important;
        border-radius: 14px !important;
        margin-bottom: 24px !important;
    }

    .promo-warning-box::before {
        display: none !important;
    }

    .warning-title {
        font-size: 0.94rem !important;
        margin-bottom: 12px !important;
    }

    .countdown-timer {
        gap: 8px !important;
        margin-bottom: 12px !important;
    }

    .countdown-item {
        padding: 11px 9px !important;
        min-width: 68px !important;
        border-radius: 10px !important;
    }

    .countdown-number  { font-size: 1.7rem !important; }
    .countdown-label   { font-size: 10px !important; margin-top: 3px !important; }
    .countdown-separator { font-size: 1.25rem !important; line-height: 1 !important; }
    .kuota-sisa        { font-size: 0.85rem !important; }


    /* =====================================================
       5. REGISTRATION SECTION
    ===================================================== */

    .program-registration-section {
        margin: 28px 0 !important;
    }

    .registration-title {
        font-size: 1.28rem !important;
        line-height: 1.3 !important;
        margin-bottom: 8px !important;
    }

    .registration-subtitle {
        font-size: 0.85rem !important;
        margin-bottom: 18px !important;
    }

    .btn-warning {
        width: 100% !important;
        max-width: 100% !important;
        padding: 14px 18px !important;
        font-size: 0.93rem !important;
        border-radius: 10px !important;
        gap: 8px !important;
    }

    .btn-warning i { font-size: 1.1rem !important; }

    .program-registration-section .text-muted.mt-3.small {
        font-size: 0.8rem !important;
        margin-top: 10px !important;
    }


    /* =====================================================
       6. WHATSAPP ADMIN — DIPERKECIL & NAIK
    ===================================================== */

    .admin-wa-section {
        margin: 16px 0 !important;        /* ← naik lebih dekat section sebelumnya */
    }

    .wa-title {
        font-size: 1.1rem !important;
        margin-bottom: 4px !important;
    }

    .wa-subtitle {
        font-size: 0.8rem !important;
        margin-bottom: 14px !important;
    }

    /* Tombol WA diperkecil */
    .admin-wa-section .col-12 {
        display: flex !important;
        justify-content: center !important;
    }

    .btn-success {
        max-width: 260px !important;      /* ← lebih kecil dari full width */
        width: 100% !important;
        padding: 11px 16px !important;    /* ← padding lebih kecil */
        font-size: 0.88rem !important;
        border-radius: 10px !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 3px !important;
    }

    .btn-success i {
        font-size: 1.2rem !important;
        margin-right: 0 !important;
    }

    .btn-success small {
        font-size: 0.72rem !important;
        opacity: 0.88;
    }

    /* Modal WA */
    #waAdminModal .modal-dialog   { margin: 12px !important; }
    #waAdminModal .modal-content  { border-radius: 16px !important; }
    #waAdminModal .modal-header   { padding: 14px 18px !important; border-radius: 16px 16px 0 0 !important; }
    #waAdminModal .modal-title    { font-size: 1rem !important; }
    #waAdminModal .modal-body     { padding: 16px !important; }
    #waAdminModal .card-body      { padding: 13px !important; }
    #waAdminModal .admin-avatar i { font-size: 2rem !important; }
    #waAdminModal .admin-card h5  { font-size: 0.9rem !important; }
    #waAdminModal .admin-card p.text-muted   { font-size: 0.76rem !important; }
    #waAdminModal .admin-card .text-success  { font-size: 0.8rem !important; }
    #waAdminModal .alert-light    { font-size: 0.77rem !important; padding: 8px 12px !important; }
    #waAdminModal .modal-footer   { padding: 12px 16px !important; }


    /* =====================================================
       7. BENEFITS SECTION
    ===================================================== */

    .creator-benefits { padding: 32px 0 !important; }

    .benefits-title {
        font-size: 1.32rem !important;
        margin-bottom: 26px !important;
        letter-spacing: 0.5px !important;
        padding: 0 4px !important;
        line-height: 1.3 !important;
    }

    .creator-benefit-card {
        padding: 20px 14px !important;
        border-radius: 14px !important;
    }

    .creator-benefit-icon {
        width: 54px !important;
        height: 54px !important;
        margin-bottom: 13px !important;
    }

    .creator-benefit-icon i { font-size: 1.35rem !important; }
    .benefit-title          { font-size: 1rem !important; margin-bottom: 8px !important; }
    .benefit-description    { font-size: 0.84rem !important; line-height: 1.55 !important; padding-bottom: 12px !important; }
    .promo-code-box         { padding: 8px 10px !important; }
    .code-label             { font-size: 0.74rem !important; }
    .code-value             { font-size: 0.86rem !important; }


    /* =====================================================
       8. HOW IT WORKS
    ===================================================== */

    .how-it-works { margin: 28px 0 !important; }

    .works-title {
        font-size: 1.32rem !important;
        margin-bottom: 28px !important;
        padding: 0 4px !important;
    }

    .works-title::after {
        width: 65px !important;
        bottom: -10px !important;
    }

    .how-it-works .row {
        --bs-gutter-x: 10px !important;
        --bs-gutter-y: 10px !important;
    }

    .step-card {
        padding: 15px 11px !important;
        border-radius: 12px !important;
    }

    .step-number {
        width: 42px !important;
        height: 42px !important;
        font-size: 1.15rem !important;
        margin-bottom: 11px !important;
        line-height: 42px !important;
    }

    .step-card h5 { font-size: 0.93rem !important; margin-bottom: 7px !important; line-height: 1.3 !important; }
    .step-card p  { font-size: 0.79rem !important; line-height: 1.5 !important; }


    /* =====================================================
       9. PLATFORM SUPPORT
    ===================================================== */

    .platform-support {
        padding: 22px 16px !important;
        margin: 28px 0 !important;
        border-radius: 16px !important;
    }

    .platform-title {
        font-size: 1.12rem !important;
        margin-bottom: 18px !important;
    }

    .platform-icons {
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px !important;
    }

    .platform-icon div {
        width: 100% !important;
        max-width: 240px !important;
        padding: 11px 20px !important;
        font-size: 0.9rem !important;
        border-radius: 40px !important;
        min-width: unset !important;
    }

    .platform-follow-text {
        font-size: 0.83rem !important;
        margin-top: 16px !important;
    }


    /* =====================================================
       10. TERMS & CONDITIONS
    ===================================================== */

    .quick-terms { margin: 28px 0 !important; }

    .terms-note {
        padding: 18px 15px !important;
        border-radius: 12px !important;
    }

    .terms-note .d-flex {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
    }

    .terms-note .me-3            { margin-right: 0 !important; }
    .terms-note i.bi-shield-check { font-size: 1.65rem !important; }
    .terms-note h6               { font-size: 0.98rem !important; margin-bottom: 10px !important; }
    .terms-note ul               { padding-left: 4px !important; }
    .terms-note li               { font-size: 0.82rem !important; padding-left: 18px !important; margin-bottom: 7px !important; line-height: 1.5 !important; }


    /* =====================================================
       11. FOOTER — SEMUA RATA TENGAH
    ===================================================== */

    .footer-modern {
        padding: 30px 0 16px !important;
        text-align: center !important;        /* ← rata tengah global */
    }

    /* Logo center */
    .footer-modern .col-lg-4 {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    .footer-logo {
        height: 44px !important;
        margin: 0 auto 12px !important;       /* ← center logo */
        display: block !important;
    }

    .footer-modern p {
        font-size: 0.84rem !important;
        line-height: 1.55 !important;
        text-align: center !important;
    }

    /* Social links center */
    .social-links {
        display: flex !important;
        justify-content: center !important;
        gap: 20px !important;
        margin-top: 12px !important;
    }

    .social-links a i {
        font-size: 1.4rem !important;
    }

    /* Headings center */
    .footer-modern h5 {
        font-size: 0.93rem !important;
        margin-top: 6px !important;
        margin-bottom: 12px !important;
        text-align: center !important;
        letter-spacing: 1px !important;
    }

    /* Footer links center */
    .footer-links {
        text-align: center !important;
    }

    .footer-links li {
        margin-bottom: 8px !important;
        text-align: center !important;
    }

    .footer-links a {
        font-size: 0.84rem !important;
    }

    /* Footer links hover: hilangkan shift kiri */
    .footer-links a:hover {
        padding-left: 0 !important;
    }

    /* Contact info center */
    .footer-contact {
        text-align: center !important;
    }

    .footer-contact li {
        margin-bottom: 10px !important;
        justify-content: center !important;   /* ← center icon + teks */
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .footer-contact i {
        font-size: 0.92rem !important;
        min-width: auto !important;
        flex-shrink: 0;
    }

    .footer-contact span {
        font-size: 0.84rem !important;
    }

    /* Divider */
    .footer-divider {
        margin: 18px 0 14px !important;
    }

    /* Copyright */
    .footer-modern .text-center p {
        font-size: 0.76rem !important;
    }

    /* Row gap antar kolom footer */
    .footer-modern .row {
        --bs-gutter-y: 16px !important;
    }

    /* AOS lebih cepat di mobile */
    [data-aos] { transition-duration: 440ms !important; }
}


/* ============================================================
   MOBILE LARGE  (≤ 576px)
============================================================ */
@media (max-width: 576px) {

    /* Hero */
    .program-hero-section  { padding-top: 62px !important; }
    .program-hero-content  { padding: 16px 16px 24px !important; }
    .program-hero-title    { font-size: 1.6rem !important; }
    .program-hero-subtitle { font-size: 0.85rem !important; }

    /* Stats */
    .creator-stat-number { font-size: 1.65rem !important; }
    .creator-stat-item   { padding: 13px 8px !important; }
    .creator-stat-label  { font-size: 0.67rem !important; }

    /* Countdown */
    .countdown-item      { min-width: 60px !important; padding: 10px 7px !important; }
    .countdown-number    { font-size: 1.55rem !important; }
    .countdown-separator { font-size: 1.08rem !important; }

    /* Registration */
    .registration-title  { font-size: 1.16rem !important; }
    .btn-warning         { font-size: 0.87rem !important; padding: 12px 14px !important; }

    /* WA Button */
    .btn-success {
        max-width: 230px !important;
        padding: 10px 14px !important;
        font-size: 0.84rem !important;
    }

    /* Steps */
    .step-card    { padding: 13px 10px !important; }
    .step-number  { width: 38px !important; height: 38px !important; font-size: 1.05rem !important; line-height: 38px !important; margin-bottom: 9px !important; }
    .step-card h5 { font-size: 0.86rem !important; }
    .step-card p  { font-size: 0.76rem !important; }

    /* Benefits */
    .benefits-title       { font-size: 1.2rem !important; }
    .creator-benefit-card { padding: 17px 13px !important; }
    .benefit-title        { font-size: 0.97rem !important; }
    .benefit-description  { font-size: 0.81rem !important; }

    /* Platform */
    .platform-icon div { max-width: 220px !important; font-size: 0.87rem !important; padding: 10px 16px !important; }

    /* Terms */
    .terms-note li { font-size: 0.79rem !important; }

    /* Footer */
    .footer-modern h5  { font-size: 0.88rem !important; }
    .footer-links a,
    .footer-contact span { font-size: 0.81rem !important; }
}


/* ============================================================
   MOBILE SMALL  (≤ 400px)  — iPhone SE, Galaxy A kecil
============================================================ */
@media (max-width: 400px) {

    /* Navbar */
    .navbar              { height: 58px !important; padding: 0 12px !important; }
    .navbar .container   { height: 58px !important; }
    .navbar-brand img    { height: 35px !important; }
    .navbar-toggler      { width: 40px !important; height: 40px !important; }
    .navbar-toggler-icon { width: 19px !important; height: 19px !important; }
    .navbar-collapse     { top: 58px !important; }

    /* Hero */
    .program-hero-section  { padding-top: 58px !important; }
    .program-hero-content  { padding: 14px 14px 22px !important; }
    .program-hero-title    { font-size: 1.42rem !important; }
    .program-hero-subtitle { font-size: 0.8rem !important; }

    /* Stats */
    .creator-stats-counter { padding: 16px 9px !important; margin: 18px auto !important; }
    .creator-stat-number   { font-size: 1.48rem !important; }
    .creator-stat-item     { padding: 11px 6px !important; }
    .creator-stat-label    { font-size: 0.63rem !important; }

    /* Countdown */
    .countdown-item      { min-width: 52px !important; padding: 9px 6px !important; }
    .countdown-number    { font-size: 1.38rem !important; }
    .countdown-separator { font-size: 0.9rem !important; }
    .countdown-label     { font-size: 9px !important; }

    /* Registration */
    .registration-title { font-size: 1.06rem !important; }
    .btn-warning        { font-size: 0.83rem !important; padding: 11px 12px !important; }

    /* WA Button */
    .btn-success {
        max-width: 210px !important;
        padding: 9px 12px !important;
        font-size: 0.82rem !important;
    }

    /* Steps */
    .step-number  { width: 35px !important; height: 35px !important; font-size: 0.95rem !important; line-height: 35px !important; }
    .step-card h5 { font-size: 0.81rem !important; }
    .step-card p  { font-size: 0.72rem !important; }

    /* Benefits */
    .creator-benefit-card { padding: 15px 11px !important; }
    .benefit-title        { font-size: 0.93rem !important; }
    .benefit-description  { font-size: 0.78rem !important; }

    /* Modal */
    #waAdminModal .modal-dialog   { margin: 8px !important; }
    #waAdminModal .admin-avatar i { font-size: 1.75rem !important; }
    #waAdminModal .admin-card h5  { font-size: 0.84rem !important; }

    /* Footer */
    .footer-modern p,
    .footer-links a,
    .footer-contact span { font-size: 0.79rem !important; }
    .footer-modern h5    { font-size: 0.85rem !important; }
}


/* ============================================================
   TOUCH DEVICE — hapus hover transform, pakai :active
============================================================ */
@media (hover: none) and (pointer: coarse) {

    .creator-benefit-card:hover,
    .step-card:hover,
    .creator-stat-item:hover,
    .platform-icon:hover div,
    .btn-warning:hover,
    .btn-success:hover {
        transform: none !important;
        box-shadow: none !important;
    }

    .creator-benefit-card:active,
    .step-card:active       { transform: scale(0.97) !important; }
    .btn-warning:active,
    .btn-success:active     { transform: scale(0.95) !important; opacity: 0.88 !important; }
    .platform-icon:active div { transform: scale(0.97) !important; }
    .admin-card:active      { transform: scale(0.98) !important; }

    a, button {
        -webkit-tap-highlight-color: rgba(255, 140, 0, 0.12);
    }
}


/* ============================================================
   END — program-responsive.css v3.0
============================================================ */